<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <script>
        const vm = {
            _data: {
                name: 'laowang',
                age: 18,
                count: 0
            }
        }

        // 数据代理的实现
        // Object.keys(vm._data) 返回的是一个数组，可以用 for of遍历
        for (let key of Object.keys(vm._data)) {
            Object.defineProperty(vm, key, {
                get: function proxyGetter() {
                    return vm._data[key]
                },
                set: function proxySetter(newVal) {
                    vm._data[key] = newVal
                }
            })
        }
    </script>
</body>

</html>